Android组件化开发之路(二)URL Scheme使用

什么是 URL Scheme?

android中的scheme是一种页面内跳转协议,通过定义自己的scheme协议,可以跳转app中的各个页面;通过scheme协议,服务器可以定制化告诉App跳转那个页面,可以通过通知栏消息定制化跳转页面,可以通过H5页面跳转页面等。

URL Scheme应用场景

客户端应用可以向操作系统注册一个 URL scheme,该 scheme 用于从浏览器或其他应用中启动本应用。通过指定的 URL 字段,可以让应用在被调起后直接打开某些特定页面,比如商品详情页、活动详情页等等。也可以执行某些指定动作,如完成支付等。也可以在应用内通过 html 页来直接调用显示 app 内的某个页面。综上URL Scheme使用场景大致分以下几种:

  1. 服务器下发跳转路径,客户端根据服务器下发跳转路径跳转相应的页面
  2. H5页面点击锚点,根据锚点具体跳转路径APP端跳转具体的页面
  3. APP端收到服务器端下发的PUSH通知栏消息,根据消息的点击跳转路径跳转相关页面
  4. APP根据URL跳转到另外一个APP指定页面

URL Scheme协议格式

先来个完整的URL Scheme协议格式:

1
http://baidu:8080/newsDetail?type=1&id=10001

通过上面的路径 Scheme、Host、port、path、query全部包含,基本上平时使用路径就是这样子的。

  1. http代表该Scheme 协议名称
  2. baidu代表Scheme作用于哪个地址域
  3. newsDetail代表Scheme指定的页面
  4. type和id代表传递的参数
  5. 8080代表该路径的端口号

URL Scheme如何使用

1.)在AndroidManifest.xml中对标签增加设置Scheme

1
2
3
4
5
6
7
8
9
10
11
12
13
<activity
android:name=".NewsDetailActivity"
android:theme="@style/AppTheme">
<!--要想在别的App上能成功调起App,必须添加intent过滤器-->
<intent-filter>
<!--协议部分,随便设置-->
<data android:scheme="http" android:host="baidu" android:path="/newsDetail" android:port="8080"/>
<!--下面这几行也必须得设置-->
<category android:name="android.intent.category.DEFAULT"/>
<action android:name="android.intent.action.VIEW"/>
<category android:name="android.intent.category.BROWSABLE"/>
</intent-filter>
</activity>

2.)获取Scheme跳转的参数

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
Uri uri = getIntent().getData();
if (uri != null) {
// 完整的url信息
String url = uri.toString();
Log.e(TAG, "url: " + uri);
// scheme部分
String scheme = uri.getScheme();
Log.e(TAG, "scheme: " + scheme);
// host部分
String host = uri.getHost();
Log.e(TAG, "host: " + host);
//port部分
int port = uri.getPort();
Log.e(TAG, "host: " + port);
// 访问路劲
String path = uri.getPath();
Log.e(TAG, "path: " + path);
List<String> pathSegments = uri.getPathSegments();
// Query部分
String query = uri.getQuery();
Log.e(TAG, "query: " + query);
//获取指定参数值
String type=uri.getQueryParameter("type");
String id = uri.getQueryParameter("id");
Log.e(TAG, "type: " + type);
Log.e(TAG, "id: " + id);
}

3.)调用方式

网页调用:

1
<a href="http://baidu:8080/newsDetail?type=1&id=10001">打开新闻详情</a>

原生调用

1
2
Intent intent = new Intent(Intent.ACTION_VIEW,Uri.parse("http://baidu:8080/newsDetail?type=1&id=10001"));
startActivity(intent);

4.)如何判断一个Scheme是否有效

1
2
3
4
5
6
7
PackageManager packageManager = getPackageManager();
Intent intent = new Intent(Intent.ACTION_VIEW, Uri.parse("http://baidu:8080/newsDetail?type=1&id=10001"));
List<ResolveInfo> activities = packageManager.queryIntentActivities(intent, 0);
boolean isValid = !activities.isEmpty();
if (isValid) {
startActivity(intent);
}

热评文章